题目说明
1 | 给你一个整数数组 nums ,请你找出数组中乘积最大的连续子数组(该子数组中至少包含一个数字),并返回该子数组所对应的乘积。 |
解题思路一
- 该题与之前所写的560.和为K的子数组很相似,解法也都是一样的。
- 依旧是对前缀进行操作。不同的是,我们这次不需要保留所有的结果,只需要保留本次结果的最大值
nowMax和最小值nowMin。取min主要是为了复数的情况。 - 我们依赖于上一次的状态,求出本次的最大最小值。然后传入下一次状态。
1. `nowMax = Math.max(res[0] * nums[i], res[1] * nums[i], nums[i]);` 2. `nowMin = Math.min(res[0] * nums[i], res[1] * nums[i], nums[i]);` 3. `res = [nowMax, nowMin ]` - 在此过程中我们可以求出最大值max
代码实现一
1 | /** |